**![Logo

Description automatically generated](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHkAAAB1CAMAAABd5r4AAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAJDUExURf///97KrcCXXb6WXL+XXNO2i/39/Pz6+Mytf9G0i/j18EVZZgdBaglCaghCaiRQbL2WXMCZYLaUZRVHbbuUXs6whi9NarSTaMCXXJiBY1pgar+XXQNAaAM8ZgM9Z/j4+QY6ZklJguHj6baSXx9Hcfn5+sytgf7+/s7T2YiVqvLr35mDarzCzvv7+8SaXgVAajtafRdHbqmvwIORqAA9aThMecGZYAM+aufp7a6OYrO3w19ukMXK09nDovLy9QY/aAdBabqUXi9OeJylugRBafPz93KCnwQ+Z8nN2dLU3ePm65ijtExsigZAaRlJcBVFbWRzigNBaQhBaQdCagA8Z4aPoyFIdAE9Zr6WW4GPp//+/pV+Zy9OdwZBagU9ZiZPd/Hz9b+XXgM7ahtGaRM9bfb39wI3ZAdAaCBHariSXKCEXgZBaUJVaL+WWwhAabyUXL2VXAQ/aAA0Z3CBmvz8/QI/afPz9Yl2Y35vZL6XXYKLo494ZFdebJumugA2ZQdAauXn7Orh1wExZcCdbJ6DYTJMaGx7l3BpZAE4ZO7v87mTXOXWxIKQqJWkuARAaNve5AdAabWQXTdQZ9W9mAQ8Zr+WXAFAadPV3UdggBVIdv7+/wY8ZyVLa4SSpQAzZwA/amx9k/T19/n29D5ZfQE+avv7/czO2tG4mQY4ZKaIYbK3yiFIatze5XB7ml1uktnCoY59a8moeOrdywVCau7j1drEpFZha+/l2A9CatzGpw1CasajcQ5Eav///v79/Pfy6wAAAAAd6RIAAADBdFJOU////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////wCINFSNAAAACXBIWXMAACHVAAAh1QEEnLSdAAAKWklEQVRoQ+1bPatkxxGdDcwL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) San Francisco Bay University**

**EE488 - Computer Architecture**

**Homework Assignment #7**

**Due day: 4/21/2023**

**Instruction:**

1. **Push the answer sheet to GitHub in word file.**
2. **Overdue homework submission could not be accepted.**
3. **Takes academic honesty and integrity seriously (Zero Tolerance of Cheating & Plagiarism)**
4. (Bonus) Write two Verilog modules to design a 4-bits multiplier which implements Booth’s algorithm and one of multiplication algorithms from 3 versions shown in the handout of *Lec06-alu.pdf,* respectively.

**4-bits multiplier:**

module booth\_multiplier(

input signed [3:0] multiplicand,

input signed [3:0] multiplier,

output reg signed [7:0] product

);

reg signed [7:0] product\_reg;

reg [4:0] m;

reg [4:0] a;

reg [2:0] q;

always @(\*) begin

product\_reg = 8'b0;

m = {1'b0, multiplicand};

a = {4'b0, multiplier};

q = 3'b0;

repeat(4) begin

// check last two bits of q and E1

case ({q[1], q[0], q[2]})

3'b001, 3'b010 : product\_reg = product\_reg - m;

3'b100, 3'b011 : product\_reg = product\_reg + m;

default : begin end

endcase

// shift right

q = {a[0], q[2:1]};

a = {a[4], a[3:1]};

end

// check if multiplier is negative

if (multiplier[3] == 1) begin

product\_reg = -product\_reg;

end

product = product\_reg; // assign the result to the output

end

endmodule

**Testbench:**

module booth\_multiplier\_tb;

// Inputs

reg [3:0] multiplicand;

reg [3:0] multiplier;

// Outputs

wire [7:0] product;

// Instantiate the Unit Under Test (UUT)

booth\_multiplier uut (

.multiplicand(multiplicand),

.multiplier(multiplier),

.product(product)

);

// Clock generation

reg clk = 0;

always #5 clk = ~clk;

// Stimulus

initial begin

// Create a VCD dump file

$dumpfile("booth\_multiplier.vcd");

$dumpvars(0, booth\_multiplier\_tb);

// test 1

multiplicand = 4'b0101;

multiplier = 4'b0011;

#10;

$display("Product = %d", product);

// test 2

multiplicand = 4'b1001;

multiplier = 4'b0010;

#10;

$display("Product = %d", product);

// test 3

multiplicand = 4'b0110;

multiplier = 4'b1010;

#10;

$display("Product = %d", product);

// test 4

multiplicand = 4'b0010;

multiplier = 4'b1001;

#10;

$display("Product = %d", product);

// test 5

multiplicand = 4'b1111;

multiplier = 4'b0101;

#10;

$display("Product = %d", product);

// test 6

multiplicand = 4'b0000;

multiplier = 4'b0001;

#10;

$display("Product = %d", product);

// test 7

multiplicand = 4'b1111;

multiplier = 4'b1111;

#10;

$display("Product = %d", product);

// test 8

multiplicand = 4'b1010;

multiplier = 4'b0101;

#10;

$display("Product = %d", product);

// test 9

multiplicand = 4'b1101;

multiplier = 4'b1011;

#10;

$display("Product = %d", product);

// test 10

multiplicand = 4'b0010;

multiplier = 4'b0001;

#10;

$display("Product = %d", product);

// End simulation

#10 $finish;

end

// Clock driver

always #2.5 clk = ~clk;

endmodule

**Multiplication algorithms from 3 versions:**

***Design:***

module booth\_multiplier(clk, rst, multiplicand, multiplier, product);

input clk, rst;

input [3:0] multiplicand, multiplier;

output reg [7:0] product;

reg [4:0] counter;

reg [3:0] complement;

initial begin

counter = 4;

complement = ~multiplicand + 1;

product = 0;

end

always @(posedge clk) begin

if (rst) begin

counter <= 4;

complement <= ~multiplicand + 1;

product <= 0;

end

else begin

case ({multiplier[3], multiplier[2], multiplier[1]}) // examine three bits at a time

3'b000, 3'b111: product <= {product[6:0], product[7]}; // shift right

3'b001, 3'b100: product <= product; // no change

3'b010: product <= product + complement; // add complement

3'b101: product <= product - complement; // subtract complement

endcase

counter <= counter - 1;

end

end

endmodule

***Testbench :***

*module booth\_multiplier\_tb();*

*reg clk, rst;*

*reg [3:0] multiplicand, multiplier;*

*wire [7:0] product;*

*booth\_multiplier dut(.clk(clk),*

*.rst(rst),*

*.multiplicand(multiplicand),*

*.multiplier(multiplier),*

*.product(product));*

*initial begin*

*clk = 0;*

*rst = 0;*

*multiplicand = 4'b0101;*

*multiplier = 4'b1011;*

*#10 rst = 1;*

*#10 rst = 0;*

*#10 multiplicand = 4'b1111;*

*#10 multiplier = 4'b0001;*

*#10 $finish;*

*end*

*always #5 clk = ~clk;*

*endmodule*

1. (Bonus) Write two Verilog modules to design a 4-bits divisor which implements any two of division algorithms from 3 versions shown in the handout of *Lec07-division.pdf,* respectively.

**Design 1:**

**Dividend: 101101**

**Divisor: 0101**

module booth\_division\_v3 (

input [5:0] dividend,

input [3:0] divisor,

output reg [1:0] quotient,

output reg [3:0] remainder

);

reg [3:0] complement;

reg [2:0] state = 0;

reg [5:0] dividend\_shifted;

always @(\*) begin

// Initialize complement register

complement = ~divisor + 1;

// Append 0s to dividend

dividend\_shifted = {2'b00, dividend};

// Perform division using Booth's algorithm version 3

for (int i = 0; i < 6; i = i + 3) begin

case (dividend\_shifted[i+2:i])

3'b000, 3'b111: begin

quotient = quotient << 1;

dividend\_shifted = dividend\_shifted << 1;

end

3'b001, 3'b110: begin

quotient = quotient;

dividend\_shifted = dividend\_shifted << 1;

end

3'b010: begin

quotient = quotient << 1;

dividend\_shifted = dividend\_shifted + complement;

dividend\_shifted = dividend\_shifted << 1;

end

3'b101: begin

quotient = quotient << 1;

quotient[0] = 1;

dividend\_shifted = dividend\_shifted - complement;

dividend\_shifted = dividend\_shifted << 1;

end

endcase

end

// Remove appended 0s from dividend to obtain remainder

remainder = dividend\_shifted[5:2];

end

endmodule

**Testbench:**

module booth\_division\_v3\_tb;

reg [5:0] dividend;

reg [3:0] divisor;

wire [1:0] quotient;

wire [3:0] remainder;

booth\_division\_v3 dut (

.dividend(dividend),

.divisor(divisor),

.quotient(quotient),

.remainder(remainder)

);

initial begin

dividend = 6'b101101;

divisor = 4'b0101;

#10;

$display("Quotient: %b", quotient);

$display("Remainder: %b", remainder);

$finish;

end

endmodule

**Design2**

**Dividend: 1101011**

**Divisor: 1001**

module booth\_division\_v3 (

input [7:0] dividend,

input [3:0] divisor,

output reg [3:0] quotient,

output reg [3:0] remainder

);

reg [3:0] complement;

reg [2:0] state = 0;

reg [7:0] dividend\_shifted;

always @(\*) begin

// Initialize complement register

complement = ~divisor + 1;

// Append 0s to dividend

dividend\_shifted = {2'b00, dividend};

// Perform division using Booth's algorithm version 3

for (int i = 0; i < 8; i = i + 3) begin

case (dividend\_shifted[i+2:i])

3'b000, 3'b111: begin

quotient = quotient << 1;

dividend\_shifted = dividend\_shifted << 1;

end

3'b001, 3'b110: begin

quotient = quotient;

dividend\_shifted = dividend\_shifted << 1;

end

3'b010: begin

quotient = quotient << 1;

dividend\_shifted = dividend\_shifted + complement;

dividend\_shifted = dividend\_shifted << 1;

end

3'b101: begin

quotient = quotient << 1;

quotient[0] = 1;

dividend\_shifted = dividend\_shifted - complement;

dividend\_shifted = dividend\_shifted << 1;

end

endcase

end

// Remove appended 0s from dividend to obtain remainder

remainder = dividend\_shifted[7:4];

end

endmodule

**Testbench**

module booth\_division\_v3\_tb;

reg [7:0] dividend;

reg [3:0] divisor;

wire [3:0] quotient;

wire [3:0] remainder;

booth\_division\_v3 dut (

.dividend(dividend),

.divisor(divisor),

.quotient(quotient),

.remainder(remainder)

);

initial begin

dividend = 8'b11010110;

divisor = 4'b1001;

#10;

$display("Quotient: %b", quotient);

$display("Remainder: %b", remainder);

$finish;

end

endmodule